// 权限控制
// 这里编写路由权限控制代码
import store from '@/store'
import router from '@/router'
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'
import { getToken } from './utils/auth'

const WHITE_LIST = ['/login', '/404'] // 白名单

// 路由前置守卫
router.beforeEach((to, from, next) => {
  // to：将要跳转到的路由对象
  // from：来源路由对象
  // next：放行函数（分支中有且只有一个next函数）
  // 开启进度条
  NProgress.start()
  const token = getToken()

  if (token) {
    if (to.path === '/login') {
      next('/')
    } else {
      next()
      // 通过用户id做判断
      if (!store.state.user.userInfo.userId) {
        store.dispatch('user/fetchUserInfo')
      }
    }
  } else {
    if (WHITE_LIST.includes(to.path)) {
      // 在白名单中
      next()
    } else {
      next('/login')
    }
  }
  // 技术进度条
  NProgress.done()
})
